草庐IT

PHPUnit Laravel 哈希不可用

全部标签

ruby - 将 Ruby 哈希转换为 YAML

我需要将如下提供的散列转换为可读的YAML。看起来我可以为YAML::load提供一个字符串,但我想我需要先将它转换成这样的内容:hostname1.test.com:public:51private:10{"hostname1.test.com"=>{"public"=>"51","private"=>"10"},"hostname2.test.com"=>{"public"=>"192","private"=>"12"}}虽然我不确定如何有效地转换成该字符串。我查看了HASH文档,找不到任何关于to_yaml的内容。我通过搜索to_yaml找到了它,当您requireyaml时它就

ruby - 以有条件的方式构建哈希

我正在使用RubyonRails3.0.10,我想以有条件的方式构建哈希键\值对。也就是说,如果条件匹配,我想添加一个键及其相关值:hash={:key1=>value1,:key2=>value2,#Thiskey2\value2pairshouldbeaddedonly'ifcondition'is'true':key3=>value3,...}我怎样才能做到这一点并保持代码的“良好”可读性?我是否“被迫”使用merge方法? 最佳答案 我更喜欢tap,因为我认为它提供了比这里描述的解决方案更清晰的解决方案,因为它不需要对元素进

ruby-on-rails - 如何按降序对哈希值进行排序并在 ruby​​ 中输出哈希值?

output.sort_by{|k,v|v}.reverse和keyh={"a"=>1,"c"=>3,"b"=>2,"d"=>4}=>{"a"=>1,"c"=>3,"b"=>2,"d"=>4}Hash[h.sort]现在我有这两个。但我正在尝试按值降序对哈希进行排序,以便它返回=>{"d"=>4,"c"=>3,"b"=>2,"a"=>1}提前致谢。编辑:让我发布整个代码。defcount_words(str)output=Hash.new(0)sentence=str.gsub(/,/,"").gsub(/'/,"").gsub(/-/,"").downcasewords=senten

ruby - Ruby 中数组和哈希的性能

我有一个程序可以存储一个类的多个实例,比如说多达10,000个或更多。类实例有几个我不时需要的属性,但其中最重要的一个是ID。classDocumentattr_accessor:iddef==(document)document.id==self.idendend现在,存储数千个此类对象的最快方法是什么?我曾经将它们全部放入一个文档数组中:documents=Array.newdocuments现在另一种方法是将它们存储在哈希中:documents=Hash.newdoc=Document.newdocuments[doc.id]=doc#etc在我的应用程序中,我主要需要查明文档是

ruby - 将 CSV 文件转换为哈希数组

我有一个csv文件,一些曲棍球统计数据,例如:09.09.2008,1,HCVitkoviceSteel,BKMladaBoleslav,1:0(PP)09.09.2008,1,HCLasselsbergerPlzen,RIOKNAZLIN,6:209.09.2008,1,HCLitvinov,HCSpartaPraha,3:5我想将它们保存在一个哈希数组中。我没有任何header,我想为每个值添加键,例如"time"=>"09.09.2008"等等。每行都应该像arr[i]一样可访问,每个值都应该像arr[i]["time"]一样可访问。我更喜欢CSV类而不是FasterCSV或sp

Ruby 哈希默认值行为

我正在检查RubyKoans,我点击了#41,我相信它是这样的:deftest_default_value_is_the_same_objecthash=Hash.new([])hash[:one]它无法理解这种行为,所以我用谷歌搜索并找到了StrangerubybehaviorwhenusingHashdefaultvalue,e.g.Hash.new([])很好地回答了这个问题。所以我明白它是如何工作的,我的问题是,为什么默认值(例如递增的整数)在使用过程中不会改变?例如:puts"Textplease:"text=gets.chompwords=text.split("")fre

ruby - 是否有等效于 `Array::sample` 的哈希值?

我想从哈希中提取n个随机键值对。 最佳答案 Hash[original_hash.to_a.sample(n)]对于Ruby2.1,original_hash.to_a.sample(n).to_h 关于ruby-是否有等效于`Array::sample`的哈希值?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/15454632/

arrays - 在 Ruby 中将数组转换为索引哈希

我有一个数组,我想做一个散列,这样我就可以快速询问“数组中有X吗?”。在perl中,有一种简单(快速)的方法可以做到这一点:my@array=qw(123);my%hash;@hash{@array}=undef;这会生成一个哈希值,如下所示:{1=>undef,2=>undef,3=>undef,}我在Ruby中想到的最好的是:array=[1,2,3]hash=Hash[array.map{|x|[x,nil]}]给出:{1=>nil,2=>nil,3=>nil}是否有更好的Ruby方法?编辑1不,Array.include?这不是一个好主意。它慢。它在O(n)而不是O(1)中执行

ruby - 确定一个值是否存在于哈希数组中

我有以下内容:array_of_hashes=[{:a=>10,:b=>20},{:a=>11,:b=>21},{:a=>13,:b=>23}]如果:a=>11存在于array_of_hashes中,我将如何查找array_of_hashes.include?似乎不起作用 最佳答案 array_of_hashes.any?{|h|h[:a]==11} 关于ruby-确定一个值是否存在于哈希数组中,我们在StackOverflow上找到一个类似的问题: http

Ruby:更新哈希值最简单的方法是什么?

说:h={1=>10,2=>20,5=>70,8=>90,4=>34}我想将每个值v更改为foo(v),这样h将是:h={1=>foo(10),2=>foo(20),5=>foo(70),8=>foo(90),4=>foo(34)}实现此目标的最优雅方法是什么? 最佳答案 您可以使用update(merge!的别名)使用block更新每个值:hash.update(hash){|key,value|value*2}请注意,我们正在有效地将hash与其自身合并。这是必需的,因为Ruby将调用block来解决任何碰撞键的合并,并使用bl